<script setup>
import { ref, computed } from 'vue';
import { getAgentListAPI, getAgentOrderListAPI } from '@/api/distribution';
import { useInitTable } from '@/composables/useCommon'
const props = defineProps({
  type: {
    type: String,
    default: 'user'
  }
})
const drawerTitle = computed(() => {
  return props.type === 'user' ? '推广人列表' : '推广订单列表'
})
const {
  searchForm,
  tableData,
  loading,
  total,
  currentPage,
  getData,
} = useInitTable(
  {
    searchForm: {
      type: 'all',
      starttime: null,
      endtime: null,
      level: 0,
      user_id: 0
    },
    getList: (() => {
      return props.type === 'user' ? getAgentListAPI : getAgentOrderListAPI
    })(),
    onGetListSuccess: (res) => {
      tableData.value = res.list
      total.value = res.totalCount
    },
  }
)

const dialogVisible = ref(false)

const resetSearchForm = () => {
  searchForm.value.type = 'all'
  searchForm.value.starttime = null
  searchForm.value.endtime = null
  searchForm.value.level = 0
}
const open = (id) => {
  dialogVisible.value = true
  searchForm.value.user_id = id
  getData()
}
defineExpose({
  open
})
</script>

<template>
  <el-drawer :title="drawerTitle" v-model="dialogVisible" size="70%">
    <!-- 搜索 -->
    <el-form :model="searchForm" size="small">
      <el-form-item label="时间选择">
        <el-radio-group v-model="searchForm.type">
          <el-radio-button value="all">全部</el-radio-button>
          <el-radio-button value="today">今天</el-radio-button>
          <el-radio-button value="yesterday">昨天</el-radio-button>
          <el-radio-button value="last7days">最近7天</el-radio-button>
        </el-radio-group>
      </el-form-item>
      <el-form-item label="开始时间">
        <el-date-picker v-model="searchForm.starttime" type="date" placeholder="开始日期" style="width: 90%;"
          value-format="YYYY-MM-DD" />
      </el-form-item>
      <el-form-item label="结束时间">
        <el-date-picker v-model="searchForm.endtime" type="date" placeholder="结束日期" style="width: 90%;"
          value-format="YYYY-MM-DD" />
      </el-form-item>
      <el-form-item label="用户类型">
        <el-radio-group v-model="searchForm.level">
          <el-radio-button :value="0">全部</el-radio-button>
          <el-radio-button :value="1">一级推广</el-radio-button>
          <el-radio-button :value="2">二级推广</el-radio-button>
        </el-radio-group>
      </el-form-item>
      <el-form-item>
        <el-button type="primary" @click="getData">搜索</el-button>
        <el-button @click="resetSearchForm">重置</el-button>
      </el-form-item>

    </el-form>
    <!-- 表格区域 -->
    <el-table class="mt-3" v-loading="loading" :data="tableData" border stripe>
      <template v-if="props.type === 'user'">
        <el-table-column label="ID" prop="id" align="center"></el-table-column>
        <el-table-column label="头像" width="65">
          <template #default="scope">
            <!-- 头像 -->
            <el-avatar :size="40" :src="scope.row.avatar">
              <img src="https://cube.elemecdn.com/e/fd/0fc7d20532fdaf769a25683617711png.png" />
            </el-avatar>
          </template>
        </el-table-column>

        <el-table-column label="用户信息" prop="username"></el-table-column>
        <el-table-column label="推广数" prop="share_num" align="center"></el-table-column>
        <el-table-column label="推广订单数" prop="share_order_num" align="center"></el-table-column>
        <el-table-column label="绑定时间" prop="create_time" align="center"></el-table-column>
      </template>
      <template v-else>
        <el-table-column label="订单号">
          <template #default="{ row }">
            {{ row.order.no }}
          </template>
        </el-table-column>
        <el-table-column label="用户名|昵称|手机">
          <template #default="{ row }">
            <div v-if="!row.order.user">
              该用户已被删除
            </div>
            <div v-else>
              {{ row.order.user.username }}|{{ row.order.user.nickname }}|{{ row.order.user.phone }}
            </div>
          </template>
        </el-table-column>
        <el-table-column label="时间" prop="create_time"></el-table-column>
        <el-table-column label="返佣金额" prop="commission"></el-table-column>


      </template>
    </el-table>
    <el-pagination class="flex justify-center mt-auto-3" background layout="prev, pager, next" :total="total"
      :current-page="currentPage" @current-change="getData" />

  </el-drawer>

</template>